Holds all informations related to GPU programs, and manages their compilation. More...
 
  
Holds all informations related to GPU programs, and manages their compilation.
| nkGraphics::Program::Program | ( | ) | 
Constructor. See ShaderManager::createOrRetrieveProgram().
| 
 | virtual | 
Destructor.
| const ProgramCompilationResult& nkGraphics::Program::getLastCompilationResult | ( | ) | const | 
| bool nkGraphics::Program::isFromFile | ( | ) | const | 
| bool nkGraphics::Program::isFromMemory | ( | ) | const | 
| ProgramSourcesHolder* nkGraphics::Program::getMemory | ( | ) | const | 
| const InfiniteByteMask& nkGraphics::Program::getSemantics | ( | ) | const | 
| unsigned int nkGraphics::Program::getId | ( | ) | const | 
| PROGRAM_TYPE nkGraphics::Program::getType | ( | ) | const | 
| PROGRAM_COMPILATION_PROFILE nkGraphics::Program::getProfile | ( | ) | const | 
| 
 | virtual | 
Sets the program from an already loaded memory set.
The memory used will need to fit some constraints for a Program to find back relevant data :
| memory | The memory to use. | 
| 
 | virtual | 
Sets the defines to use within the program. Can be useful to add defines and then load a program from a folder.
| memory | The memory to copy de defines from. | 
| void nkGraphics::Program::setFromFiles | ( | const nkMemory::StringView & | folder | ) | 
Sets the folder from which the program should load its sources. The files that can be loaded are :
With x being the extension set through the setFileExtensions() function, or the default which depends on the type of renderer :
| folder | The path of the folder to load from, relative to the working directory. See nkResources::ResourceManager for the path naming conventions. | 
| void nkGraphics::Program::setFileExtensions | ( | const nkMemory::StringView & | value | ) | 
Sets the extension to search for when parsing the given folder. This allows to override the default behavior of the file seeking algorithm, enabling to put in common files loaded for all type of renderers, for instance.
| value | The extension to append to the file names. | 
| void nkGraphics::Program::setId | ( | unsigned int | id | ) | 
Sets the id of the program.
| id | The id to use. | 
| void nkGraphics::Program::setProfile | ( | PROGRAM_COMPILATION_PROFILE | profile | ) | 
Sets the profile to use for compilation.
| profile | The profile to use. | 
| void nkGraphics::Program::setActivateCrossCompilerDefines | ( | bool | value | ) | 
Activates or not the cross compiler defines feeding. This is a good tool to use if you plan on making your programs work both on DirectX and OpenGL based renderers. Setting this to true will enable keywords within hlsl / glsl sources to ease cross-platform development. By default, this flag is off to lower processing times while loading programs. 
 If set to on, new keywords will become available to program sources, that will translate correctly into both languages : 
| Nk keyword | Hlsl translation | Glsl translation | |
|---|---|---|---|
| Types | |||
| nkBool2 | bool2 | bvec2 | |
| nkBool3 | bool3 | bvec3 | |
| nkBool4 | bool4 | bvec4 | |
| nkFloat2 | float2 | vec2 | |
| nkFloat3 | float3 | vec3 | |
| nkFloat4 | float4 | vec4 | |
| nkInt2 | int2 | ivec2 | |
| nkInt3 | int3 | ivec3 | |
| nkInt4 | int4 | ivec4 | |
| nkUint2 | uint2 | uvec2 | |
| nkUint3 | uint3 | uvec3 | |
| nkUint4 | uint4 | uvec4 | |
| nkFloat2x2 | float2x2 | mat2 | |
| nkFloat3x3 | float3x3 | mat3 | |
| nkFloat4x4 | float4x4 | mat4 | |
| nkFloat2x4 | float2x4 | mat2x4 | |
| Textures types | |||
| nkTexture2d(name, slot) | Texture2D [name] : register(t[slot]) | layout(binding = [slot]) uniform sampler2D [name] | |
| nkTextureCube(name, slot) | TextureCube [name] : register(t[slot]) | layout(binding = [slot]) uniform samplerCube [name] | |
| nkSampler(name, slot) | SamplerState [name] : register(s[slot]) | bool [name] (no valid translation) | |
| Textures functions | |||
| nkSample(tex, sampler, uvs) | [tex].Sample([sampler], [uvs]) | texture([tex], [uvs]) | |
| nkSampleBias(tex, sampler, uvs, bias) | [tex].SampleBias([sampler], [uvs], [bias]) | texture([tex], [uvs], [bias]) | |
| nkSampleLevel(tex, sampler, uvs, level) | [tex].SampleLevel([sampler], [uvs], [level]) | textureLod([tex], [uvs], [level]) | |
| nkLoad(tex, texel) | [tex].Load([texel]) | texelFetch([tex], [texel.xy], [texel.z]) | |
| nkLoadOffset(tex, texel, offset) | [tex].Load([texel], [offset]) | texelFetchOffset([tex], [texel.xy], [texel.z], [offset]) | |
| Constant types | |||
| nkConstantBuffer(name, slot) | cbuffer [name] : register(b[slot]) | layout(binding = [slot], std140) uniform [name] | |
| Comparison functions | |||
| nkLessThan(a, b) | ([a] < [b]) | lessThan([a], [b]) | |
| General functions | |||
| nkMul(a, b) | mul([a], [b]) | ([a] * [b]) | |
| nkAtan2(a, b) | atan2([a], [b]) | atan([a], [b]) | |
| nkFrac(a) | frac([a]) | fract([a]) | |
| nkSaturate(a) | saturate([a]) | clamp([a], 0, 1) | |
| nkDdx(a) | ddx([a]) | dFdx([a]) | |
| nkDdy(a) | ddy([a]) | dFdy([a]) | |
| nkLerp(a, b, c) | lerp([a], [b], [c]) | mix([a], [b], [c]) | |
| value | Whether the defines should be set (true) or not (false). | 
| bool nkGraphics::Program::prepareMemoryWithFiles | ( | ) | 
If the program is defined from a folder, prepares the memory with the source files content.
| 
 | pure virtual | 
Loads the program, from the memory currently set.
| 
 | pure virtual | 
Tries to load from a provided memory, and swap the current state with the newly submitted state only on success. If it fails, the program state is not changed.
| newMemory | The memory to try to load from. | 
| 
 | overridevirtual | 
Loads and compiles the program. 
 When processing the compilation, a program will automatically add some defines to help with cross renderer development : 
 Allowing to write code that will differentiate between both compilers : 
 
#if defined(NK_HLSL)
    float4 main (in float4 pos : SV_POSITION) : SV_TARGET
    {
        return 1 ;
    }
#elif defined(NK_GLSL)
    out vec4 color ;
    void main ()
    {
        color = vec4(1) ;
    }
#endif
 Implements nkGraphics::Resource.
| 
 | overridevirtual | 
Unloads and frees the internal resources of the program.
Implements nkGraphics::Resource.
| 
 | overridevirtual | 
Basic exporting capabilities.
| rootNode | The tree to export to. | 
Implements nkExport::Exportable.
| 
 | overridevirtual | 
Basic importing capabilities.
| rootNode | The tree to import from. | 
Implements nkExport::Exportable.